

FIG. 1



FIG. 2



FIG. 3





FIG. 5



FIG. 6



FIG. 7



FIG. 8



TDI USERS 382 -TDI FILTER DRIVER 380 -& UPPER LAYER INTERFACE 370~ **ATCP** 360 -358 **TCP -350** -355 366 -IP ΙP 363 MAC MAC -353 375 **NDIS** INIC MINIPORT DRIVER 377

FIG. 11



FIG. 10



FIG. 12

10/82











15/82



FIG. 16



FIG. 17



FIG. 18



FIG. 19

| ISR   | 0x0            | Interrupt Status            |
|-------|----------------|-----------------------------|
| IMR   | 0x4            | Interrupt Mask              |
| HBAR  | 0x8            | Header Buffer Address       |
| DBHR  | 0xC            | Data Buffer Handle          |
| DBAR  | 0x10           | Data Buffer Address         |
| CBAR0 | 0x14           | Command Buffer Address XMT0 |
| CBAR1 | 0x18           | Command Buffer Address XMT1 |
| CBAR2 | 0x1C           | Command Buffer Address XMT2 |
| CBAR3 | $0x20^{\circ}$ | Command Buffer Address XMT3 |
| CBAR4 | 0x24           | Command Buffer Address RCV  |
| RBAR  | 0x28           | Response Buffer Address     |
|       |                | ·                           |

FIG. 20



FIG. 21



FIG. 22



FIG. 23



FIG. 24

FIG. 25





FIG. 27



FIG. 28



FIG. 29

# SRAM requirements for the Receive and Transmit engines:

| TCB buffers      | 256 bytes* 16                  | 4096             |
|------------------|--------------------------------|------------------|
| Header buffers   | 256 bytes* 16<br>128 bytes* 16 | 2048             |
| TCB hash index   | 16 bytes* 256                  | 4096             |
| Timers           | •                              | 128              |
| DRAM Fifo queues | 128 bytes* 16                  | 2048             |
| -                | -                              | $\sim$ 12K bytes |

# Summary of the main loop of Receive:

```
forever {

while there are any Receive events {

if (a new event) {

if (no new context available)

ignore the event;

}

call appropriate event handler to service the event;

this may make a waiting process runnable or set up

a new process to be run (get free context, hddr buffer,

TCB buffer, set the context up).

}

while any process contexts are runable {

run them by jumping to the start/resume address;

if (process complete)

free the context;

}
```

## Format of the SMB header of an SMB frame:

31 0 NetBIOS header **TYPE FLAGS** LENGTH "S" "M" "B" SMB header 0xFF **COM RCLS** ERR... REH REB/FLG ...ERR Reserved Reserved Reserved Reserved TID PID UID MID **WCT** VWV[] **BCC** Data...

Notes (interesting fields):

LENGTH 17 bit Length of SMB message (0 - 128K)

COM SMB command

WCT Count (16 bit) of parameter words in VWV []

VWV Variable number of parameter words

BCC Bytes of data following

FIG. 32

## **Summary of the main loop of Transmit:**

```
forever {

while there are any Transmit events {

if (a new event) {

if (no new context available)

ignore the event;

}

call appropriate event handler to service the event;

this may make a waiting process runnable or set up

a new process to be run (get free context, hddr buffer,

TCB buffer, set the context up).

}

while any process contexts are runable {

run them by jumping to the start/resume address;

if (process complete)

free the context;

}
```

Bit 31 - 24 Byte enable 7 - 0. Only the low order four bits are valid for 32 bit addressing mode.

Bit 23 - 0 Memory access

1 Configuration access

Bit 22 - 0 Read (to Host)

1 Write (to Host)

Bit 21 - 1 Data Valid

Bit 20 - 16 Reserved

Bit 15 - 0 Address

# FIG. 34

| Configuration Space 1 | SRAM Address Offset |
|-----------------------|---------------------|
| 00                    | 00                  |
| 04                    | 04                  |
| 08                    | 08                  |
| 0C                    | 0C                  |
| 10                    | 10                  |
| 3C                    | 14                  |
|                       |                     |
|                       |                     |

## Configuration Space 2

| 00 | 00 |
|----|----|
| 04 | 18 |
| 08 | 08 |
| 0C | 1C |
| 10 | 20 |
| 3C | 24 |

All other reads to configuration space will return 00.

Bit 0 - 0 I/O accesses are not enabled
Bit 1 - 1 Memory accesses are enabled
Bit 2 - 1 Bus master is enabled
Bit 3 - 0 Special Cycle is not enabled
Bit 4 - 1 Memory Write and Invalidate is enabled
Bit 5 - 0 VGA palette snooping is not enabled
Bit 6 - 1 Parity checking is enabled
Bit 7 - 0 Address data stepping is not enabled
Bit 8 - SERR# is enabled
Bit 9 - 0 Fast back to back is not enabled

# FIG. 36

Bit 5 - 1 66 MHz capable is enabled. This bit will be set if the INIC Detects the system running at 66 MHz on reset Bit 6 - 0 User Definable Features is not enabled Bit 7 - 1 Fast Back-to-Back slave transfers enabled Bit 8 - 1 Parity Error enabled - This bit is initialized to 0 Bit 9,10 - 00 - Fast device select will be set if we are at 33 MHz 01 - Medium device select will be set if we are at 66 MHz Target Abort is implemented. Initialized to 0. Bit 11 - 1 Bit 12 - 1 Target Abort is implemented. Initialized to 0. Master Abort is implemented. Initialized to 0. Bit 13 - 1 Bit 14 - 1 SERR# is implemented. Initialized to 0. Bit 15 - 1 Parity error is implemented. Initialized to 0.



FIG. 38

| MODULE                                                                          | <u>DESCR</u>                                                                                                                                                | <u>SPEED</u>                                                                      |                                         | <u>AREA</u>                                                                                                                                                                     |
|---------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|-----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Scratch RAM,<br>WCS,<br>MAP,<br>ROM,<br>REGs,<br>Macs,<br>PLL,<br>MISC LOGIC, 1 | 1Kx128 sport,<br>8Kx49 sport,<br>128x7 sport,<br>1Kx49 32col,<br>512x32 tport,<br>.75 mm <sup>2</sup> x 4 =<br>.5 mm <sup>2</sup> =<br>17,260 gates / (503) | 4.37 ns nom.,<br>6.40 ns nom.,<br>3.50 ns nom.,<br>5.00 ns nom.,<br>6.10 ns nom., |                                         | 06.77 mm <sup>2</sup> 18.29 mm <sup>2</sup> 00.24 mm <sup>2</sup> 00.45 mm <sup>2</sup> 03.49 mm <sup>2</sup> 03.30 mm <sup>2</sup> 00.55 mm <sup>2</sup> 23.29 mm <sup>2</sup> |
| TOTAL CORE                                                                      | , , , , , , , , , , , , , , , , , , , ,                                                                                                                     | U                                                                                 |                                         | 56.22 mm <sup>2</sup>                                                                                                                                                           |
| (Core side) <sup>2</sup> Core side Die side Die area                            | = core side + 1.0<br>= 8.5 mm x 8.5 n                                                                                                                       | ,                                                                                 | ======================================= | 56.22 mm <sup>2</sup><br>07.50 mm<br>08.50 mm<br>72.25 mm <sup>2</sup>                                                                                                          |
| Pads needed<br>LSI PBGA                                                         | = 220 signals x 1                                                                                                                                           | .25 (vss, vdd)                                                                    | =                                       | 275 pins<br>272 pins                                                                                                                                                            |

FIG. 39

| (10MB/s/100Base) x 2 (full duplex) x 4 connections                              | = | 80 MB/s            |
|---------------------------------------------------------------------------------|---|--------------------|
| Average frame size                                                              | = | 512 B              |
| Frame rate = $80MB/s / 512B$                                                    | = | 156,250 frames / s |
| Cpu overhead / frame = (256B context read) + (64B header read) +                |   |                    |
| (128B context write) + (128B misc.)                                             | = | 512B / frame       |
| Total bandwidth = $(512B \text{ in}) + (512B \text{ out}) + (512B \text{ Cpu})$ | = | 1536B / frame      |
| Dram Bandwidth required = (1536B/frame) x (156,250 frames/s)                    | = | 240MB/s            |
| Dram Bandwidth @ 60MHz = (32 bytes / 167ns)                                     | = | 202MB/s            |
| Dram Bandwidth @ 66MHz = (32 bytes / 150ns)                                     | = | 224MB/s            |
| PCI Bandwidth required                                                          | = | 80MB/s             |
| PCI Bandwidth available @ 30 MHz, 32b, average                                  | = | 46MB/s             |
| PCI Bandwidth available @ 33 MHz, 32b, average                                  | = | 50MB/s             |
| PCI Bandwidth available @ 60 MHz, 32b, average                                  | = | 92MB/s             |
| PCI Bandwidth available @ 66 MHz, 32b, average                                  | = | 100MB/s            |
| PCI Bandwidth available @ 30 MHz, 64b, average                                  | = | 92MB/s             |
| PCI Bandwidth available @ 33 MHz, 64b, average                                  | = | 100MB/s            |
| PCI Bandwidth available @ 60 MHz, 64b, average                                  | = | 184MB/s            |
| PCI Bandwidth available @ 66 MHz, 64b, average                                  | = | 200MB/s            |
|                                                                                 |   | J                  |

```
Receive frame interval = 512B / 40MB/s = 12.8us
Instructions / frame @ 60MHz = (12.8us/frame) / (50ns/instruction) = 256
instructions / frame @ 66MHz = (12.8us/frame) / (45ns/instruction) = 284
instructions/frame
Required instructions / frame = 250 instructions/frame
```



FIG. 42

## **INSTRUCTION-WORD FORMAT**

| <b>TYPE</b> | <u>[55:49]</u> | [48:47] | [46:42] | [41:33]      | [32:24]      | [23:16] | [15:00] |
|-------------|----------------|---------|---------|--------------|--------------|---------|---------|
| Jcc         | 0ь0000000      | 0600,   | AluOp,  | OpdASel,     | OpdBSel,     | TstSel, | Literal |
| Jmp         | 0Ь0000000      | 0b01,   | AluOp,  | OpdASel,     | OpdBSel,     | FlgSel, | Literal |
| Jsr         | 0ь0000000      | 0b10,   | AluOp,  | OpdASel,     | OpdBSel,     | FlgSel, | Literal |
| Rts         | 0Ь0000000      | 0b11,   | AluOp,  | OpdASel,     | OpdBSel,     | 0hff,   | Literal |
| Nxt         | 0ь0000000      | 0b11,   | AluOp,  | OpdASel,     | OpdBSel,     | FlgSel, | Literal |
| Map         | MapAddr        | 0BXX, 0 | вХХХХХ, | 0вXXXXXXXXX, | OBXXXXXXXXX, | 0нХХ,   | 0нХХХХ  |

```
SEQUENCER BEHAVIOR
 if (MapEn & (MapAddr!= 0b0000000)){
Stackc = Stackc;
StackB = StackB;
                                                                             //re-map instr
             StackA = StackA
           InstrAddr = 0h8000 | Pc[2:0] | (MapAddr << 3);
             Pc = InstrAddr + (Execute & ~DbgMd);
Fetch = DbgMd? DbgAddr:InstrAddr;
            DbgAddr = DbgAddr + (Execute & DbgMd);
else if (PgmCtrl == Jcc){
Stackc = Stackc;
                                                                             //conditional jump
             StackB = StackB;
             StackA = StackA;
           InstrAddr = ~Tst@TstSel? Pc:(AluDst==Pc)? AluOut:Literal;
               Pc = InstrAddr + (Execute \& \sim DbgMd)
             Fetch = DbgMd? DbgAddr:InstrAddr;
            DbgAddr = DbgAddr + (Execute & DbgMd);}
else if (PgmCtrl == Jmp){
Stackc = Stackc;
StackB = StackB;
                                                                             //jump
            StackA = StackA;
          InstrAddr = (AluDst == Pc)? AluOut:Literal;
             Pc = InstrAddr + (Execute & ~DbgMd)
Fetch = DbgMd? DbgAddr:InstrAddr;
            DbgAddr = DbgAddr + (Execute & DbgMd);}
else if (PgmCtrl == Jsr){
                                                                             //jump subroutine
            Stacke = StackB;
StackB = StackA;
            StackA = Pc;
          InstrAddr = (AluDst == Pc) ? AluOut:Literal;
             Pc = InstrAddr + (Execute & ~DbgMd)
Fetch = DbgMd? DbgAddr:InstrAddr;
           DbgAddr = DbgAddr + (Execute & DbgMd);
else if (FlgSel == Rts){
    InstrAddr = StackA;
                                                                             //return subroutine
            StackA = StackB;
StackB = Stacke;
            Stackc = ErrVec;
               Pc = InstrAddr + (Execute \& \sim DbgMd)
             Fetch = DbgMd? DbgAddr:InstrAddr;
           DbgAddr = DbgAddr + (Execute & DbgMd);}
else
          InstrAddr = Pc;
                                                                             //continue
           StackA = StackA;
StackB = StackB;
            Stackc = Stackc:
            Pc = InstrAddr + (Execute & ~DbgMd)
Fetch = DbgMd ? DbgAddr:InstrAddr;
           DbgAddr = DbgAddr + (Execute & DbgMd);}
```

FIG. 44

## **ALU OPERATIONS**

| AluOp   | OPERATION .                                                                                   |                   |
|---------|-----------------------------------------------------------------------------------------------|-------------------|
| 0ь00000 | $A = (A \& \sim (1 << B));$<br>C = 0; V = (B >= 32) ? 1:0;                                    | //bit clear       |
| 0b00001 | A = (A & B);<br>C = 0; V = 0;                                                                 | //logical and     |
| 0ь00010 | A = (Literal & B);<br>C = 0; V = 0;                                                           | //logical and     |
| 0b00011 | $\mathbf{A} = (\sim \mathbf{Literal} \ \& \ \mathbf{B});$ $\mathbf{C} = 0; \ \mathbf{V} = 0;$ | //logical and not |
| 0b00100 | $A = (A   (1 \le B));$<br>$C = 0; V = (B \ge 32) ? 1:0;$                                      | //bit set         |
| 0b00101 | $\mathbf{A} = (\mathbf{A} \mid \mathbf{B});$ $\mathbf{C} = 0; \mathbf{V} = 0;$                | //logical or      |
| 0600110 | $\mathbf{A} = (\mathbf{Literal} \mid \mathbf{B});$ $\mathbf{C} = 0; \mathbf{V} = 0;$          | //logical or      |
| 0600111 | $\mathbf{A} = (\sim \mathbf{Literal} \mid \mathbf{B});$ $\mathbf{C} = 0; \mathbf{V} = 0;$     | //logical or not  |
| 0ь01000 | for (i=31; i>=0; i) if $B[i]$ continue; $A=i$ ; $C=0$ ; $V=(B)$ ? 0:1;                        | //priority enc    |
| 0ь01001 | $\mathbf{A} = (\mathbf{A} \wedge \mathbf{B});$ $\mathbf{C} = 0; \mathbf{V} = 0;$              | //logical xor     |
| 0ь01010 | $A = (\{Literal\} ^B);$ $C = 0; V = 0;$                                                       | //logical xor     |
| 0b01011 | $A = ({\sim Literal} ^ B);$ $C = 0; V = 0;$                                                   | //logical xor not |
| 0b01100 | $\mathbf{A} = \mathbf{B};$ $\mathbf{C} = 0; \mathbf{V} = 0;$                                  | //move            |
| 0b01101 | $A = B[31:24] ^B[23:16] ^B[15:08] ^B[07:00];$<br>C = 0; V = 0;                                | //hash            |
| 0b01110 | $A = \{B[23:16], B[31:24], B[07:00], B[15:08]\};$<br>C = 0; V = 0;                            | //swap bytes      |
| 0b01111 | $A = {B[15:00], B[31:16]};$<br>C = 0; V = 0;                                                  | //swap doublets   |

FIG. 45

| <u>AluOp</u> | FUNCTION                                                        |                        |
|--------------|-----------------------------------------------------------------|------------------------|
| 0b10000      | A = (A + B);<br>C = (A + B)[32]; V = 0;                         | //add <b>B</b>         |
| 0b10001      | A = (A + B + C);<br>C = (A + B + C)[32]; V = 0;                 | //add <b>B, carry</b>  |
| 0b10010      | A = (Literal + B);<br>C = (Literal + B)[32]; V = 0;             | //add constant         |
| 0b10011      | A = (-Literal + B);<br>C = (-Literal + B)[32]; V = 0;           | //sub constant         |
| 0b10100      | A = (A - B);<br>C = (A - B)[32]; V = 0;                         | //sub <b>B</b>         |
| 0b10101      | $A = (A - B - \sim C);$<br>$C = (A - B - \sim C)[32]; V = 0;$   | //sub <b>B, borrow</b> |
| 0b10110      | A = (-A + B);<br>C = (-A + B)[32]; V = 0;                       | //sub A                |
| 0b10111      | $A = (-A + B - \sim C);$<br>$C = (-A + B - \sim C)[32]; V = 0;$ | //sub <b>A, borrow</b> |
| 0b11000      | $A = (A \le B);$<br>$C = A[31]; V = (B \ge 32) ? 0:1;$          | //shift left A         |
| 0b11001      | A = (B << Literal);<br>C = B[31]; V = (Literal >= 32) ? 0:1;    | //shift left B         |
| 0b11010      | $A = (B \le 1);$<br>C = B[31]; V = 0;                           | //shift left B         |
| 0b11011      | n = (A - B);<br>C = (A - B)[32]; V = 0;                         | //compare              |
| 0b11100      | A = (A >> B);<br>C = A[0]; V = (B >= 32) ? 1:0;                 | //shift right A        |
| 0b11101      | A = (B >> Literal);<br>C = A[0]; V = (Literal >= 32) ? 1:0;     | //shift right <b>B</b> |
| 0b11110      | A = (B >> 1);<br>C = A[0]; V = 0;                               | //shift right <b>B</b> |
| 0b11111      | n = (B - A);<br>C = (B - A)[32]; V = 0;                         | //compare              |

FIG. 46

| OpdSel       | SELECTED OF   | PERANDS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0b0000aaaaa  | File          | File@(OpdSel[4:0]   FileBase);<br>Allows paged access to any part of the register file.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 0b0001aaaaa  | CpuReg        | File@{2'b11, Cpuld, OpdSel[4:0]}; Allows direct access to Cpu specific registers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0b001XXXXXX  | reserved      | Reserved for future expansion.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0ь01000000ХХ | CpuStatus     | 0b00000000000BHD00000000000CC This is a read-only register providing information about the Cpu executing (OpdSel[1:0]) cycles after the current cycle. "CC" represents a value indicating the Cpu. Currently, only Cpuld values of 0, 1 and 2 are returned. "H" represents the current state of Hlt, "D" indicates DbgMd and "B" indicates BigMd. Writing this register has no effect.                                                                                                                                                                                          |
| 0b0100001XX  | reserved      | Reserved for future expansion.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0b0100010XX  | Pc            | 0x0000AAAA Writing to this address causes the program control logic to use AluOut as the new Pc value in the event of a Jmp, Jcc or Jsr instruction for the Cpu executing during the current cycle. If the current instruction is Nxt, Map, or Rts, the register write has no effect. Reading this register returns the value in Pc for the Cpu executing (OpdSel[1:0]) cycles after the current cycle.                                                                                                                                                                         |
| 0b0100011XX  | DbgAddr       | 0xD000AAAA Writing to this register alters the contents of the debug address register (DbgAddr) for the Cpu executing (OpdSel[1:0]) cycles after the current cycle. DbgAddr provides the fetch address for the control-store when DbgMd has been selected and the Cpu is executing. DbgAddr is also used as the control-store address when performing a WrWcs@DbgAddr or RdWcs@DbgAddr operation. "D" represents bit 31 of the register. It is a general purpose flag that is used for event indication during simulation. Reading this register returns a value of 0x00000000. |
| 0b01001XXXX  | reserved      | Reserved for future expansion.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0ь010100000  | RamAddr = Alı | CCC, 0x000, 0b1, AAAA}<br>uOut[15] ? AluOut : (AluOut   RamBase);<br>uOut[31] ? CCC : AluCC;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

A read/write register. When reading this register, the Alu condition codes from the previous instruction are returned together with **RamAddr**.

| <u>bit</u> 31 | name .  | description                         |  |
|---------------|---------|-------------------------------------|--|
| 31            |         | Always 1.                           |  |
| 30            | PrevC   | Previous Alu Carry.                 |  |
| 29            | PrevV   | Previous Alu Overflow.              |  |
| 28            | PrevZ   | Previous Alu Zero.                  |  |
| 27:16         |         | Always 0.                           |  |
| 15            |         | Always 1.                           |  |
| 14.0          | RamAddr | Contents of last Sram address used. |  |

When writing this register, if alu\_out[31] is set, the previous condition codes will be overwritten with bits 30:28 of AluOut. If AluOut[15] is set, bits 14:0 will be written to the RamAddr. If AluOut [15] is not set, bits 14:0 will be ored with the contents of the RamBase and written to the RamAddr

OpdSel\_ SELECTED OPERANDS

0b010100001 0x0000AAAA AddrRegA

AddrRegA = AluOut;

A read/write operand which loads AddrRegA used to provide the address for read and write operations. When AddrRegA[15] is set, the contents will be presented directly to the ram. When AddrRegA[15] is reset, the contents will first be ored with the contents of the RamBase register before presentation to the ram. Writing to this register takes priority over Literal loads using FlgOp. Reading this register returns the current value of the register.

0b010100010 AddrRegB 0x0000AAAA

AddrRegB = AluOut;

A read/write operand which loads AddrRegB used to provide the address for read and write

operations.

When AddrRegB[15] is set, the contents will be presented directly to the ram. When AddrRegB[15] is reset, the contents will first be ored with the contents of the RamBase register before presentation to the ram. Writing to this register takes priority over Literal loads using FlgOp. Reading this register returns the current value of the register.

AddrRegAb 0x0000AAAA AddrRegA = AluOut; AddrRegB = AluOut; 0b010100011

A destination only operand which loads **AddrRegB** and **AddrRegA** used to provide the address for read and write operations Writing to this register takes priority over Literal loads using **FlgOp**. Reading this register returns the value 0x00000000.

0x0000AAAA 0b010100100 RamBase RamBase = AluOut;

A read/write register which provides the base address for ram read and write cycles. When RamAddr[15] is set, the contents will not be used. When RamAddr[15] is reset, the contents will first be ored with the contents of the RamBase register before presentation to the ram. Reading this register returns the value for the current Cpu.

0b010100101 0b00000000000000000000AAAAAAAA FileBase = AluOut;

FileAddr = OpdSel[8] ? OpdSel:(OpdSel + FileBase);

A read/write register which provides the base address for file read and write cycles. When OpdSel[8] is set, the contents will not be used and OpdSel will be presented directly to the address lines of the file. When OpdSel[8] is reset, the contents will first be ored with the contents of the FileBase register before presentation to the file. Reading this register returns the value for the current Cpu.

0xIIIIIIII 0b010100110 InstrRegL

This is a read-only register which returns the contents of **InstrReg**[31:0]. Writing to this register has no effect.

0b010100111 InstrRegH 0x00IIIIII

> This is a read-only register which returns the contents of InstrReg[55:32]. Writing to this register has no effect.

| <u>OpdSel</u> | SELECTED O               | PERANDs                                                                                                                                                                                                                                                                             |
|---------------|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0ь010101000   | Minus!                   | 0xffffffff This is a read-only register which supplies a value 0xffffffff Writing to this register has no effect.                                                                                                                                                                   |
| 0ь010101001   | FreeTime                 | A free-running timer with a resolution of 1.00 microseconds and a maximum count of 71 minutes. This timer is cleared during reset.                                                                                                                                                  |
| 0b010101010   | LiteralL                 | Instr[15:0] A read-only register. Writing to this register has no effect                                                                                                                                                                                                            |
| 0ь010101011   | LiteralH                 | Instr[15:0]<<16; A read-only register. Writing to this register has no effect                                                                                                                                                                                                       |
| 0ь010101100   | during Mac oper          | ring to this address loads the AluOut data into the MacData register for use rations. The Mac operation, resulting from writing to the MacOp register, efinition of the MacData register contents as follows.                                                                       |
|               | MacOp<br>Mstop<br>WrMcfg | MacData definition 0bXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX                                                                                                                                                                                                                           |
|               | w.n.e.g                  | hrstl, rsvd, rsvd, crcen, fulld, hrstl, hugen, nopre, paden, prtyl, xdl10, ipgr1[6:0], ipgr2[6:0], ipgt[6:0].  Loads the MacCfg register with the contents of the MacData register. Refer to LSI Logic's Ethernet-110 Core Technical Manual for detailed definitions of these bits. |
|               | WrMrng                   | 0bXXXXXXXXXXXXXXXXXXXXXXXXSSSSSSSSSSSSS                                                                                                                                                                                                                                             |
|               | RdPhy                    | 0bXXXXRRRRXXXXPPPPXXXXXXXXXXXXXXXXXXXXXX                                                                                                                                                                                                                                            |

Reading this register returns **prsd[15:0]** of **Mac0** which contains phy status data returned to the Mac at the completion of a **RdPhy** command. This data is invalid while **MacBsy** is asserted as a result of a **RdPhy** command. Refer to the appropriate phy technical manual for a definition of the phy register contents.

Writes register[R] of phy[P] with MacData[15:0].

WrPhy

FIG. 50A

FIG. 50B

FIG. 50C

#### OpdSel SELECTED OPERANDS

0b010101101

**MacOp** - A write only register. Writing to this address loads the **MacSel** register and staRts execution of the specified operation as follows.

| <u>AluOut</u> | description                                                                    |
|---------------|--------------------------------------------------------------------------------|
| 0xXXXXX0XM    | Mstop - Halts execution of a MacOp for Mac[M]. The user must wait for          |
|               | MacBsy to be deasserted before issuing another command or changing the         |
|               | contents of MacData.                                                           |
| 0xXXXXX1XM    | WrMcfg - Writes the contents of MacData to the MacCfg register of Mac[M].      |
|               | The user must wait for MacBsy to be deasserted before issuing another command  |
|               | or changing the contents of MacData.                                           |
| 0xXXXXXXXXM   | WrMrng - Writes the contents of MacData to the seed register of Mac[M]. The    |
|               | user must wait for MacBsy to be deasserted before issuing another command or   |
|               | changing the contents of MacData.                                              |
| 0xXXXXXXXXM   | RdPhy - Reads the contents of reg[R] for phy[P] on the MII management bus of   |
|               | Mac[M]. The contents may be read from MacData after MacBsy has been de-        |
|               | asserted.                                                                      |
| 0xXXXXX4XM    | WrPhy - Writes the contents of MacData[15:0] to e reg[R] of phy[P] on the MII  |
|               | management bus of Mac[M]. The user must wait for MacBsy to be deasserted       |
|               | before issuing another command or changing the contents of MacData.            |
| 0xXXXXX8XM    | WrAddrAL - Writes the contents of MacData[15:0] to MacAddrA[15:0] for Mac[M].  |
| 0xXXXXX9XM    | WrAddrAH - Writes the contents of MacData[11:0] to MacAddrA[47:16] for Mac[M]. |
| 0xXXXXXXaXM   | WrAddrBL - Writes the contents of MacData[15:0] to MacAddrB[15:0] for Mac[M].  |
| 0xXXXXXbXM    | WrAddrBH - Writes the contents of MacData[11:0] to MacAddrB[47:16] for Mac[M]. |

b010101110 **ChCmd** 

A write-only register.

| bit name          | description                                                 |
|-------------------|-------------------------------------------------------------|
| 31:11 reserved    | Data written to these bits is ignored.                      |
| 10:8 command      | 0 - Stops execution of the current operation and clears the |
|                   | corresponding event flag.                                   |
|                   | 1 - Transfer data from ExtMem to ExtMem.                    |
|                   | 2 - Transfer data from Pci to ExtMem.                       |
|                   | 3 - Transfer data from ExtMem to Pci.                       |
|                   | 4 - Transfer data from Sram to ExtMem.                      |
|                   | 5 - Transfer data from ExtMem to Sram.                      |
|                   | 6 - Transfer data from Pci to Sram.                         |
|                   | 7 - Transfer data from Sram to Pci.                         |
| 07:05 reserved    | Data written to these bits is ignored.                      |
| 04:00 <b>ChId</b> | Provides the channel number for the channel command.        |

FIG. 50A

| 0b010101110 | ChEvr                | nt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | A read-only register.                                                                                                                                                                                                                                               |
|-------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | <u>bit</u> 31:00     | name<br>ChDn                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | description  Each bit represents the done flag for the respective dma channel. These bits are set by a dma sequencer upon completion of the channel command. Cleared when the processor writes 0 to the corresponding ChCmd register.                               |
| 06010101111 | GenEv                | nt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | A read-only register.                                                                                                                                                                                                                                               |
|             | bit<br>31<br>30      | name<br>PciRdEvnt<br>PciWrEvnt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Indicates that a PCI initiator is attempting to read a mproc. register.  Indicates that a PCI initiator has posted a write to a mproc.                                                                                                                              |
|             | 29<br>28:00          | TimeEvnt reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | register. An event which occurs once every 2.00 milliseconds. Reserved for future use.                                                                                                                                                                              |
| 0b010110000 | QCtrl                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | A write-only register used to select and manipulate a Q.                                                                                                                                                                                                            |
|             | bit<br>31:11<br>10:8 | reserved Data of Part | Enables all queues.  Bdy Increments the QBdyRdPtr and increments the QTIWrPtr.  Bdy Decrements the QBdyWrPtr and increments the QHdRdPtr.  Returns a queue entry in register QData  Reserved. Not to be used.  Q Set the queue status to empty and initializes QSz. |

FIG. 50B

| 4:0         | QId             | Specifies the queue on which to perform all operations except $\mathbf{DblQ}$ or $\mathbf{EnQ}$ .                                                                                                                                                                                                                                                                                                                                              |
|-------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0b010110001 | QData           | A read/write register. Writing this register will result in the data being pushed on to the selected queue. Reading this register fetches queue data popped off during the previous RdQ operation.                                                                                                                                                                                                                                             |
| 06010110010 | reserved        | Reserved for future expansion.                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0b010110011 | XcvCtrl         | A write-only register used to enable and disable Mac transmit and receive sub-channels.                                                                                                                                                                                                                                                                                                                                                        |
|             | <u>bit</u> name | description                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|             |                 | d Data written to these bits are ignored.                                                                                                                                                                                                                                                                                                                                                                                                      |
|             | 8 enable        | When set, indicates to the Mac transmit or receive sequencer that the subchannel contains a transmit or receive descriptor.                                                                                                                                                                                                                                                                                                                    |
|             | 07:05 reserve   | ed Data written to these bits is ignored.                                                                                                                                                                                                                                                                                                                                                                                                      |
|             | 04 RevCh        | Selects a Mac receive subchannel when set. Selects a Mac transmit subchannel                                                                                                                                                                                                                                                                                                                                                                   |
|             | 02              | when cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|             |                 | d Data written to this bit are ignored.  Selects subchannel B when set or A when reset.                                                                                                                                                                                                                                                                                                                                                        |
|             |                 | Provides the Mac number for the subchannel enable bit.                                                                                                                                                                                                                                                                                                                                                                                         |
| 0ь010110100 | Lru             | 0x0000000A                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|             |                 | A read/write operand indicating which of the 16 entries is least recently used. When Reading This register the least recently used entry is returned, after which it is automatically made the most recently used entry. This register should only be read in conjunction with a 'Move' operation of the ALU, else the results are unpredictable. Writing to this register forces the addressed entry to become the least recently used entry. |
| 0b010110101 | Mru             | 0x0000000A                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|             |                 | A write only operand forcing the addressed entry to become the most recently used entry.                                                                                                                                                                                                                                                                                                                                                       |
| 0b010111000 | QInRdy          | A read-only register comprising QHd not full flags for each of the 32 queues.                                                                                                                                                                                                                                                                                                                                                                  |
| 0b010111001 | QOutRdy         | A read-only register comprising QTI not empty flags for each of the 32 queues.                                                                                                                                                                                                                                                                                                                                                                 |
| 0b010111010 | QEmpty          | A read-only register comprising <b>QEmpty</b> flags for each of the 32 queues.                                                                                                                                                                                                                                                                                                                                                                 |
| 0ь010111011 | QFull           | A read-only register comprising QFull flags for each of the 32 queues.                                                                                                                                                                                                                                                                                                                                                                         |
| 0b0101111XX | reserved        | Reserved for future expansion.                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0b0110XXXXX | Constants       | {0b000, <b>OpdSel</b> [4:0]}                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 0b01110XXXX | reserved        | Reserved for future expansion.                                                                                                                                                                                                                                                                                                                                                                                                                 |

FIG. 50C

| <u>OpdSel</u> | SELEC                                                                                                              | TED O                                                                                                         | PERAN                                         | <u>Ds</u>                                                                                                                |                                                                                                                              |                                                                                 |                                                                                                                                              |                                                                                                                              |  |
|---------------|--------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|-----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|--|
| 0b01111XXXX   | Sram O                                                                                                             | PERAT                                                                                                         | IONS                                          |                                                                                                                          |                                                                                                                              |                                                                                 |                                                                                                                                              |                                                                                                                              |  |
|               | OpdSel<br>0<br>1                                                                                                   | [3]                                                                                                           | PostAc<br>nop<br>RamA                         | <u>ddrOp</u><br>ddr = Ra                                                                                                 | mAddr                                                                                                                        | + (OpdS                                                                         | cl[1:0]);                                                                                                                                    |                                                                                                                              |  |
|               | OpdSel<br>0<br>1                                                                                                   | [2]                                                                                                           | don't tr                                      | ose Ctrl<br>anspose<br>ose bytes                                                                                         |                                                                                                                              |                                                                                 |                                                                                                                                              |                                                                                                                              |  |
|               | OpdSel<br>0<br>1<br>2<br>3                                                                                         | [1:0]                                                                                                         | RamO<br>quadlet<br>triplet<br>doublet<br>byte |                                                                                                                          |                                                                                                                              |                                                                                 |                                                                                                                                              |                                                                                                                              |  |
|               | _RAI                                                                                                               | M REAL                                                                                                        | ) ATTR                                        | IBUTES                                                                                                                   |                                                                                                                              | SOUF                                                                            | RCE OP                                                                                                                                       | ERAND                                                                                                                        |  |
|               | endian mode little little little little little little little little little BIG | trans- pose 0 0 0 1 1 1 0 0 0 1 1 1 1 1 1 1 1 1 1                                                             |                                               | Sram data abcd abcX abXX abXX abcd abcX abXX abcX abXX abcd XXcd Xbcd XXcd XXxd abcd XXXd                                | sz=Q<br>abcd<br>trap<br>trap<br>trap<br>dcba<br>trap<br>trap<br>abcd<br>trap<br>trap<br>trap<br>trap<br>trap<br>trap<br>trap | sz=T Obcd Oabc trap trap Odcb Ocba trap trap Oabc Obcd trap trap Ocba Ocba trap | sz=D<br>00cd<br>00bc<br>00ab<br>trap<br>00dc<br>00cb<br>00ba<br>trap<br>00ab<br>00bc<br>00cd<br>trap<br>00ba<br>00cd<br>trap<br>00cd<br>trap | sz=B<br>000d<br>000c<br>000b<br>000a<br>000d<br>000c<br>000b<br>000a<br>000a<br>000b<br>000c<br>000d<br>000c<br>000d<br>000c |  |
|               | RAM                                                                                                                | <u>I WRIT</u>                                                                                                 | E ATTI                                        | RIBUTES                                                                                                                  | <u>s_</u> _                                                                                                                  | soui                                                                            | RCE OP                                                                                                                                       | ERAND                                                                                                                        |  |
|               | endian mode little little little little little little little big big big big big big big big                       | trans-<br>pose<br>0<br>0<br>0<br>0<br>1<br>1<br>1<br>1<br>0<br>0<br>0<br>0<br>1<br>1<br>1<br>1<br>1<br>1<br>1 |                                               | Alu out abcd XXcd XXxd abcd XXcd XXcd XXcd XXxd abcd XXcd XXcd XXcd XXcd XXxd Abcd XXxd Abcd XXXXd Abcd XXXXd Abcd XXXXd | OF=0 abcd -bcdcdd dcba -dcbdcd abcd bcd- cd dcba dcb- dc dcba                                                                | OF=1 trap bcdcd- trap. dcbdc trap -bcd -cdd- trap -dcb -dcd trap                | OF=2 trap trap cdd trap trap trap trap dcd trap trap trapcdd- trap trapdd-                                                                   | OF=3 trap trap trap trap trap trap trap trap                                                                                 |  |

0b1aaaaaaaa File File@OpdSel[8:0];
Allows direct, non-paged, access to the top half of the register file.

| TstSel     | SELECTED TEST                                                 |                                                      |
|------------|---------------------------------------------------------------|------------------------------------------------------|
| 0bX00XXXXX | Tst = TstSel[7] ^ AluOut[TstSel[4:0]]                         | //Alu bit                                            |
| 0bX0100000 | $Tst = TstSel[7] ^ C$                                         | //carry                                              |
| 0bX0100001 | $Tst = TstSel[7] ^ V$                                         | //error                                              |
| 0bX0100010 | $Tst = TstSel[7] ^ Z$                                         | //zero                                               |
| 0bX0100011 | $Tst = TstSel[7] ^(Z \mid \sim C)$                            | //less or equal                                      |
| 0bX0100100 | Tst = TstSel[7] ^ PrevC                                       | //previous carry                                     |
| 0bX0100101 | Tst = TstSel[7] ^ PrevV                                       | //previous error                                     |
| 0bX0100110 | Tst = TstSel[7] ^ PrevZ                                       | //previous zero                                      |
| 0bX0100111 | <b>Tst</b> = <b>TstSel</b> [7] ^ ( <b>PrevZ</b> & <b>Z</b> )  | //64b zero                                           |
| 0bX0101000 | $Tst = TstSel[7] \land QOpDn$                                 | //queue op okay                                      |
| 0bX0101001 | Tst = reserved                                                |                                                      |
| 0bX010101X | Tst = reserved                                                |                                                      |
| 0bX01011XX | Tst = reserved                                                |                                                      |
| 0bX0110XXX | Tst = TstSel[7] ^ Lock[TstSel[2:0]]<br>Lock(TstSel[2:0]) = 1; | //tests the current value of //the Lock then set it. |
| 0bX0111XXX | Tst = TstSel[7] ^ Lock[TstSel[2:0]]                           | //tests the value of Lock.                           |
| 0bX01XXXXX | Tst = reserved                                                |                                                      |
| 0bX1XXXXXX | Tst = reserved                                                |                                                      |

FIG. 52

| FlgSel_                 | FLAG OPERA                              | ATION                                                                                                                                                                                             |                                                                                                                                                                                                             |
|-------------------------|-----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0ь00000000              | No operation.                           |                                                                                                                                                                                                   |                                                                                                                                                                                                             |
| 0600000001              | SelfRst                                 | Forces a self reset for the eregisters                                                                                                                                                            | ntire chip excluding the PCI configuration                                                                                                                                                                  |
| 0600000010              | SelBigEnd                               | Selects big-endian mode fo                                                                                                                                                                        | r ram accesses for the current Cpu.                                                                                                                                                                         |
| 0b00000011              | SelLitEnd                               | Selects little-endian mode f                                                                                                                                                                      | or ram accesses for the current Cpu.                                                                                                                                                                        |
| 0600000100              | DbiMap                                  | Disable instruction re-mapp                                                                                                                                                                       | oing for the current Cpu.                                                                                                                                                                                   |
| 0600000101              | EnbMap                                  | Enable instruction re-mapp                                                                                                                                                                        | ing for the current Cpu.                                                                                                                                                                                    |
| 0b0000011X              | reserved                                |                                                                                                                                                                                                   |                                                                                                                                                                                                             |
| 0b00001XXX              | reserved                                |                                                                                                                                                                                                   |                                                                                                                                                                                                             |
| 0b00010XXX              | CirLck                                  | Lock[FlgSel[2:0]] = 0;                                                                                                                                                                            |                                                                                                                                                                                                             |
| 0b00011XXX              | reserved                                | Clears the semaphore regist                                                                                                                                                                       | er bit for the current Cpu only.                                                                                                                                                                            |
| 0b0010XXXX              | AddrOp                                  |                                                                                                                                                                                                   |                                                                                                                                                                                                             |
|                         | FigSel[3.2] 0 1 2 3                     | AddrSelect RamAddr = Literal[15] RamAddr = AddrRegA[15] RamAddr = AddrRegB[15] if (OpdA == RamAddr) RamAddr = AluOut[15] else if (OpdA == ram) RamAddr = AddrRegB[15] else RamAddr = AddrRegA[15] | ? Literal : (Literal   RamBase); ? AddrRegA : (AddrRegA   RamBase), ? AddrRegB : (AddrRegB   RamBase); ? AluOut : (AluOut   RamBase); ? AddrRegB : (AddrRegB   RamBase); ? AddrRegA : (AddrRegA   RamBase); |
|                         | FigSel[1.0]<br>0<br>1<br>2<br>3         | addr reg load<br>nop<br>AddrRegA = Literal,<br>AddrRegB = Literal;<br>AddrRegA = Literal;                                                                                                         | AddrRegB = Literal;                                                                                                                                                                                         |
|                         | note: When speci<br>register, before it | fying the same register for both<br>is loaded with the new value, v                                                                                                                               | n the load and select fields, the current value of the will be used for the ram address.                                                                                                                    |
| 0b0011XXXX              | reserved                                |                                                                                                                                                                                                   |                                                                                                                                                                                                             |
| 0ь01000000              | WrWcsL@Dbg                              | Causes the bits [31:0] of the written with the current Alue                                                                                                                                       | control-store at address <b>DbgAddr</b> to be <b>Out</b> data.                                                                                                                                              |
| 0b01000001              | WrWcsH@Dbg                              | Causes the bits [63:32] of the written with the current Alue                                                                                                                                      | e control-store at address <b>DbgAddr</b> to be <b>Out</b> data then increments <b>DbgAddr</b> .                                                                                                            |
| 0b01000010              | RdWcsL@Dbg                              | Causes the bits [31:0] of the moved to file address 0x1ff                                                                                                                                         | control-store at address DbgAddr to be                                                                                                                                                                      |
| 0ь01000011              | RdWcsH@Dbg                              | Causes the bits [63:32] of the moved to file address 0x1ff                                                                                                                                        | e control-store at address DbgAddr to be                                                                                                                                                                    |
| 0601000100              | reserved                                |                                                                                                                                                                                                   | •                                                                                                                                                                                                           |
| 0b010001XX              | Step                                    | Allows the Cpu (FlgSel[1:0] instruction. There is no effect                                                                                                                                       | ) cycles after the current cycle to execute a single t if the Cpu is not halted. An offset of 0 is not allowed.                                                                                             |
| 0b010010XX              | PcMd                                    |                                                                                                                                                                                                   | source for the control-store during ou (FlgSel[1:0]) cycles after the current cycle.                                                                                                                        |
| 0b010011XX              | DbgMd                                   | Selects the <b>DbgAddr</b> addres<br>control-store during instructi<br>cycles after the current cycle                                                                                             | s register as the address source for the on fetches for the Cpu (FlgSel[1:0])                                                                                                                               |
| 0b010100XX <sub>c</sub> | Hlt                                     | Halts the Cpu (FlgSel[1:0])                                                                                                                                                                       | cycles after the current cycle.                                                                                                                                                                             |
| 0b010101XX              | Run                                     | Clears Halt for the Cpu (Flgs                                                                                                                                                                     | Sel[1:0]) cycles after the current cycle.                                                                                                                                                                   |
| 0b01011XXX              | reserved                                |                                                                                                                                                                                                   |                                                                                                                                                                                                             |
| 0b011XXXXX              | reserved                                |                                                                                                                                                                                                   |                                                                                                                                                                                                             |
| 0b1XXXXXXX              | reserved                                |                                                                                                                                                                                                   | 2                                                                                                                                                                                                           |

FIG. 53



FIG. 54



FIG. 55





FIG. 57

ALIGN AND RETURN 1st Cpu Data ALIGN AND RETURN 1st DMA Data ALIGN AND RETURN 2nd Cpu Data



FIG. 58



FIG. 59



FIG. 60



FIG. 61



FIG. 62



FIG. 63



FIG. 64





FIG. 66





FIG. 68



FIG. 69



FIG. 70



FIG. 71



FIG. 72



FIG. 73



FIG. 74



FIG. 75



FIG. 76





71/82





FIG. 80

#### RECEIVE BUFFER DESCRIPTOR

| bit<br>31:30 | name     | description                                                                        |
|--------------|----------|------------------------------------------------------------------------------------|
|              | reserved |                                                                                    |
| 29:28        | size     | A copy of the bits in the FreeBufDscr.                                             |
| 27:00        | address  | Represents the last address +1 to which frame data was transferred. The address    |
|              |          | wraps around at the boundary dictated by the S bits. This can be used to determine |
|              |          | the size of the frame received                                                     |

# FIG. 81

| TIME STAMP                | OFFSET 0x0008:0x000B                                                      |
|---------------------------|---------------------------------------------------------------------------|
| bit name<br>31:00 RcvTime | The contents of FreeClk at the completion of the frame receive operation. |

## FIG. 82

| CHEC         | KSUM             | OFFSET 0x000C:0x000F                                                                                                                                                                                                                                                                                                                                                                               |
|--------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit<br>31:16 | name<br>IpChksum | description Reflects the value of the IP header checksum at frame completion or IP header completion. If an IP datagram was not detected, the checksum provides a total for the entire data portion of the received frame. The data area is defined as those bytes received after the type field of an ethernet frame, the LLC header of an 802.3 frame or the SNAP header of an 802.3-SNAP frame. |
| 15:00        | TcpChksum        | Reflects the value of the transport checksum at IP completion or frame completion. If IP was detected but session was unknown, the checksum will not include the psuedo-header. If IP was not detected, the checksum will be 0x0000.                                                                                                                                                               |
| RESER        | RVED             | OFFSET 0x0010:0x0011                                                                                                                                                                                                                                                                                                                                                                               |
| FRAM         | E Data           | OFFSET 0x0012:END OF BUFFER                                                                                                                                                                                                                                                                                                                                                                        |

#### RECEIVE BUFFER FORMAT

| FRAM                                                                                                        | 1E Status A                                                                                                                                              | OFFSET 0x0000:0x0003                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>bit_</u>                                                                                                 | name                                                                                                                                                     | description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 31                                                                                                          | attention                                                                                                                                                | Indicates one or more of the following: CompositeErr, !IpDn, !MacADet &                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 30                                                                                                          | CompositeErr                                                                                                                                             | !MacBDet, IpMcst, IpBcst, !ethernet & !802.3Snap, !Ip4, !Tcp. Set when any of the error bits of ErrStatus are set or if frame processing stops                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 30                                                                                                          | CompositeErr                                                                                                                                             | while receiving a Tcp or Udp header.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 29                                                                                                          | CtrlFrame                                                                                                                                                | A control frame was received at our unicast or special MltCst address.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 28                                                                                                          | IpDn_                                                                                                                                                    | Frame processing HIted due to exhaustion of the IP4 length counter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 27                                                                                                          | 802.3Dn                                                                                                                                                  | Frame processing HIted due to exhaustion of the 802.3 length counter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 26<br>25                                                                                                    | MacADet<br>MacBDet                                                                                                                                       | Frame's destination address matched the contents of MacAddrA.  Frame's destination address matched the contents of MacAddrB.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 24                                                                                                          | MacMest                                                                                                                                                  | The Mac detected a MItCst address.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 23                                                                                                          | MacBest                                                                                                                                                  | The Mac detected a BrdCst address.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 22                                                                                                          | IpMest                                                                                                                                                   | The frame processor detected an IP MltCst address.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 21                                                                                                          | IpBest                                                                                                                                                   | The frame processor detected an IP BrdCst address.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 20<br>19                                                                                                    | Frag<br>IpOffst                                                                                                                                          | The frame processor detected a Frag IP datagram. The frame processor detected a non-zero IP datagram offset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 18                                                                                                          | IpFigs                                                                                                                                                   | The frame processor detected a non-zero if datagram offset.  The frame processor detected flags within the IP datagram.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 17                                                                                                          | lpOpts                                                                                                                                                   | The frame processor detected a header length greater than 20 for the IP datagram.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 16                                                                                                          | TcpFlgs                                                                                                                                                  | The frame processor detected an abnormal header flag for the TCP segment.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 15                                                                                                          | TepOpts                                                                                                                                                  | The frame processor detected a header length greater than 20 for the TCP segment.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 14<br>13                                                                                                    | TcpUrg<br>CarrierEvnt                                                                                                                                    | The frame processor detected a non-zero urgent pointer for the TCP segment. Refer to E110 Technical Manual.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 12                                                                                                          | LongEvnt                                                                                                                                                 | Refer to E110 Technical Manual.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 11                                                                                                          | FrameLost                                                                                                                                                | Set when an incoming frame could not be processed as a result of an outstanding frame completion                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                                                                             |                                                                                                                                                          | event not yet serviced by the utility processor.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 10                                                                                                          | reserved                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 10<br>09:08                                                                                                 | NoAck<br>EromoTyp                                                                                                                                        | The frame processor detected a 00 - Reserved. 01- ethernet. 10 - 802.3. 11 - 802.3 Snap.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 07:06                                                                                                       | FrameTyp<br>NwkTyp                                                                                                                                       | 00 - Reserved. 01 - enternet. 10 - 802.3. 11 - 802.3 Shap. 00 - Unknown. 01 - Ip4. 10 - Ip6 11 - ip other.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 05:04                                                                                                       | TrnsptTyp                                                                                                                                                | 00 - Unknown. 01 - reserved. 10 - Tcp 11 - Udp                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 03                                                                                                          | NetBios                                                                                                                                                  | A NetBios frame was detected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                                                                                             |                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 02                                                                                                          | reserved                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 02<br>01:00                                                                                                 | reserved<br>channel                                                                                                                                      | The Mac on which this frame was received.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 02<br>01:00                                                                                                 | reserved                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 02<br>01:00<br>FRAM<br>bit                                                                                  | reserved<br>channel<br>E Status B<br>name                                                                                                                | The Mac on which this frame was received.  OFFSET 0x0004:0x0007  description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 02<br>01:00<br>FRAM<br>bit<br>31                                                                            | reserved channel (E Status B name 802.3Shrt                                                                                                              | The Mac on which this frame was received.  OFFSET 0x0004:0x0007  description  End of frame was encountered before the 802.3 length count was exhausted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 02<br>01:00<br>FRAM<br>bit<br>31<br>30                                                                      | reserved channel (E Status B  name 802.3Shrt BufOvr                                                                                                      | The Mac on which this frame was received.  OFFSET 0x0004:0x0007  description  End of frame was encountered before the 802.3 length count was exhausted.  The frame length exceded the buffer space available.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 02<br>01:00<br>FRAM<br>bit<br>31<br>30<br>29                                                                | reserved<br>channel<br>(E Status B<br>name<br>802.3Shrt<br>BufOvr<br>BadPkt                                                                              | The Mac on which this frame was received.  OFFSET 0x0004:0x0007  description  End of frame was encountered before the 802.3 length count was exhausted.  The frame length exceded the buffer space available.  Refer to E110 Technical Manual.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 02<br>01:00<br>FRAM<br>bit<br>31<br>30                                                                      | reserved channel (E Status B  name 802.3Shrt BufOvr                                                                                                      | The Mac on which this frame was received.  OFFSET 0x0004:0x0007  description  End of frame was encountered before the 802.3 length count was exhausted.  The frame length exceded the buffer space available.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 02<br>01:00<br>FRAM<br>bit<br>31<br>30<br>29<br>28<br>27<br>26                                              | reserved channel  IE Status B  name 802.3Shrt BufOvr BadPkt InvldPrmbl CrcErr DrblNbbl                                                                   | The Mac on which this frame was received.  OFFSET 0x0004:0x0007  description  End of frame was encountered before the 802.3 length count was exhausted.  The frame length exceded the buffer space available.  Refer to E110 Technical Manual.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 02<br>01:00<br>FRAM<br>bit<br>31<br>30<br>29<br>28<br>27<br>26<br>25                                        | reserved channel  IE Status B  name 802.3Shrt BufOvr BadPkt InvldPrmbl CreErr DrblNbbl CodeErr                                                           | The Mac on which this frame was received.  OFFSET 0x0004:0x0007  description  End of frame was encountered before the 802.3 length count was exhausted. The frame length exceded the buffer space available. Refer to E110 Technical Manual.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 02<br>01:00<br>FRAM<br>bit<br>31<br>30<br>29<br>28<br>27<br>26<br>25<br>24                                  | reserved channel  IE Status B  name 802.3Shrt BufOvr BadPkt InvldPrmbl CrcErr DrblNbbl CodeErr IpHdrShrt                                                 | The Mac on which this frame was received.  OFFSET 0x0004:0x0007  description  End of frame was encountered before the 802.3 length count was exhausted. The frame length exceded the buffer space available. Refer to E110 Technical Manual. The IP4 header length field contained a value less than 0x5.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 02<br>01:00<br>FRAM<br>bit<br>31<br>30<br>29<br>28<br>27<br>26<br>25<br>24<br>23                            | reserved channel  IE Status B  name 802.3Shrt BufOvr BadPkt InvldPrmbl CrcErr DrblNbbl CodeErr IpHdrShrt lpIncmplt                                       | The Mac on which this frame was received.  OFFSET 0x0004:0x0007  description  End of frame was encountered before the 802.3 length count was exhausted. The frame length exceded the buffer space available. Refer to E110 Technical Manual. The IP4 header length field contained a value less than 0x5. The frame terminated before the IP length counter was exhausted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 02<br>01:00<br>FRAM<br>bit<br>31<br>30<br>29<br>28<br>27<br>26<br>25<br>24<br>23<br>22<br>21                | reserved channel  IE Status B  name 802.3Shrt BufOvr BadPkt InvldPrmbl CrcErr DrblNbbl CodeErr IpHdrShrt IpIncmplt IpSumErr TcpSumErr                    | The Mac on which this frame was received.  OFFSET 0x0004:0x0007  description  End of frame was encountered before the 802.3 length count was exhausted. The frame length exceded the buffer space available. Refer to E110 Technical Manual. The IP4 header length field contained a value less than 0x5. The frame terminated before the IP length counter was exhausted. The IP header checksum was not 0xffff at the completion of the IP header read. The session checksum was not 0xffff at the termination of session processing.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 02<br>01:00<br>FRAM<br>bit<br>31<br>30<br>29<br>28<br>27<br>26<br>25<br>24<br>23<br>22<br>21<br>20          | reserved channel  IE Status B  name 802.3Shrt BufOvr BadPkt InvldPrmbl CrcErr DrblNbbl CodeErr IpHdrShrt lpIncmplt IpSumErr TcpSumErr TcpHdrShrt         | The Mac on which this frame was received.  OFFSET 0x0004:0x0007  description  End of frame was encountered before the 802.3 length count was exhausted. The frame length exceded the buffer space available. Refer to E110 Technical Manual. The IP4 header length field contained a value less than 0x5. The frame terminated before the IP length counter was exhausted. The IP header checksum was not 0xffff at the completion of the IP header read. The session checksum was not 0xffff at the termination of session processing. The TCP header length field contained a value less than 0x5.                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 02<br>01:00<br>FRAM<br>bit<br>31<br>30<br>29<br>28<br>27<br>26<br>25<br>24<br>23<br>22<br>21                | reserved channel  IE Status B  name 802.3Shrt BufOvr BadPkt InvldPrmbl CrcErr DrblNbbl CodeErr IpHdrShrt IpIncmplt IpSumErr TcpSumErr                    | The Mac on which this frame was received.  OFFSET 0x0004:0x0007  description  End of frame was encountered before the 802.3 length count was exhausted. The frame length exceded the buffer space available. Refer to E110 Technical Manual. The IP4 header length field contained a value less than 0x5. The frame terminated before the IP length counter was exhausted. The IP header checksum was not 0xffff at the completion of the IP header read. The session checksum was not 0xffff at the termination of session processing. The TCP header length field contained a value less than 0x5. The state of the frame processor at the time the frame processing terminated.                                                                                                                                                                                                                                                                                                                                                                                          |
| 02<br>01:00<br>FRAM<br>bit<br>31<br>30<br>29<br>28<br>27<br>26<br>25<br>24<br>23<br>22<br>21<br>20          | reserved channel  IE Status B  name 802.3Shrt BufOvr BadPkt InvldPrmbl CrcErr DrblNbbl CodeErr IpHdrShrt lpIncmplt IpSumErr TcpSumErr TcpHdrShrt         | The Mac on which this frame was received.  OFFSET 0x0004:0x0007  description  End of frame was encountered before the 802.3 length count was exhausted. The frame length exceded the buffer space available. Refer to E110 Technical Manual. The IP4 header length field contained a value less than 0x5. The frame terminated before the IP length counter was exhausted. The IP header checksum was not 0xffff at the completion of the IP header read. The session checksum was not 0xffff at the termination of session processing. The TCP header length field contained a value less than 0x5. The state of the frame processor at the time the frame processing terminated. 0b0000 Processing Mac header.                                                                                                                                                                                                                                                                                                                                                            |
| 02<br>01:00<br>FRAM<br>bit<br>31<br>30<br>29<br>28<br>27<br>26<br>25<br>24<br>23<br>22<br>21<br>20          | reserved channel  IE Status B  name 802.3Shrt BufOvr BadPkt InvldPrmbl CrcErr DrblNbbl CodeErr IpHdrShrt lpIncmplt IpSumErr TcpSumErr TcpHdrShrt         | The Mac on which this frame was received.  OFFSET 0x0004:0x0007  description  End of frame was encountered before the 802.3 length count was exhausted. The frame length exceded the buffer space available. Refer to E110 Technical Manual. The IP4 header length field contained a value less than 0x5. The frame terminated before the IP length counter was exhausted. The IP header checksum was not 0xffff at the completion of the IP header read. The session checksum was not 0xffff at the termination of session processing. The TCP header length field contained a value less than 0x5. The state of the frame processor at the time the frame processing terminated. 0b0000 Processing Mac header. 0b0001 Processing 802.3 LLC header.                                                                                                                                                                                                                                                                                                                        |
| 02<br>01:00<br>FRAM<br>bit<br>31<br>30<br>29<br>28<br>27<br>26<br>25<br>24<br>23<br>22<br>21<br>20          | reserved channel  IE Status B  name 802.3Shrt BufOvr BadPkt InvldPrmbl CrcErr DrblNbbl CodeErr IpHdrShrt lpIncmplt IpSumErr TcpSumErr TcpHdrShrt         | The Mac on which this frame was received.  OFFSET 0x0004:0x0007  description  End of frame was encountered before the 802.3 length count was exhausted. The frame length exceded the buffer space available. Refer to E110 Technical Manual. The IP4 header length field contained a value less than 0x5. The frame terminated before the IP length counter was exhausted. The IP header checksum was not 0xffff at the completion of the IP header read. The session checksum was not 0xffff at the termination of session processing. The TCP header length field contained a value less than 0x5. The state of the frame processor at the time the frame processing terminated. 0b0000 Processing Mac header. 0b0001 Processing 802.3 LLC header. 0b0011 Processing unknown network data.                                                                                                                                                                                                                                                                                |
| 02<br>01:00<br>FRAM<br>bit<br>31<br>30<br>29<br>28<br>27<br>26<br>25<br>24<br>23<br>22<br>21<br>20          | reserved channel  IE Status B  name 802.3Shrt BufOvr BadPkt InvldPrmbl CrcErr DrblNbbl CodeErr IpHdrShrt lpIncmplt IpSumErr TcpSumErr TcpHdrShrt         | The Mac on which this frame was received.  OFFSET 0x0004:0x0007  description  End of frame was encountered before the 802.3 length count was exhausted. The frame length exceded the buffer space available.  Refer to E110 Technical Manual.  The IP4 header length field contained a value less than 0x5.  The frame terminated before the IP length counter was exhausted.  The IP header checksum was not 0xffff at the completion of the IP header read.  The session checksum was not 0xffff at the termination of session processing.  The TCP header length field contained a value less than 0x5.  The state of the frame processor at the time the frame processing terminated.  0b0000 Processing Mac header.  0b0010 Processing 802.3 LLC header.  0b0011 Processing uknown network data.  0b0100 Processing IP header.                                                                                                                                                                                                                                                                      |
| 02<br>01:00<br>FRAM<br>bit<br>31<br>30<br>29<br>28<br>27<br>26<br>25<br>24<br>23<br>22<br>21<br>20          | reserved channel  IE Status B  name 802.3Shrt BufOvr BadPkt InvldPrmbl CrcErr DrblNbbl CodeErr IpHdrShrt lpIncmplt IpSumErr TcpSumErr TcpHdrShrt         | The Mac on which this frame was received.  OFFSET 0x0004:0x0007  description  End of frame was encountered before the 802.3 length count was exhausted. The frame length exceded the buffer space available. Refer to E110 Technical Manual. The IP4 header length field contained a value less than 0x5. The frame terminated before the IP length counter was exhausted. The IP header checksum was not 0xffff at the completion of the IP header read. The session checksum was not 0xffff at the termination of session processing. The TCP header length field contained a value less than 0x5. The state of the frame processor at the time the frame processing terminated. 0b0000 Processing Mac header. 0b0011 Processing 802.3 LLC header. 0b0011 Processing unknown network data. 0b0100 Processing IP header. 0b0101 Processing IP data (unknown transport).                                                                                                                                                                                                    |
| 02<br>01:00<br>FRAM<br>bit<br>31<br>30<br>29<br>28<br>27<br>26<br>25<br>24<br>23<br>22<br>21<br>20          | reserved channel  IE Status B  name 802.3Shrt BufOvr BadPkt InvldPrmbl CrcErr DrblNbbl CodeErr IpHdrShrt lpIncmplt IpSumErr TcpSumErr TcpHdrShrt         | The Mac on which this frame was received.  OFFSET 0x0004:0x0007  description  End of frame was encountered before the 802.3 length count was exhausted. The frame length exceded the buffer space available. Refer to E110 Technical Manual. The IP4 header length field contained a value less than 0x5. The frame terminated before the IP length counter was exhausted. The IP header checksum was not 0xffff at the completion of the IP header read. The session checksum was not 0xffff at the termination of session processing. The TCP header length field contained a value less than 0x5. The state of the frame processor at the time the frame processing terminated. 0b0000 Processing Mac header. 0b0010 Processing 802.3 SNAP header. 0b0011 Processing IP header. 0b0010 Processing IP header. 0b0110 Processing IP data (unknown transport). 0b0110 Processing transport header (IP data).                                                                                                                                                                |
| 02<br>01:00<br>FRAM<br>bit<br>31<br>30<br>29<br>28<br>27<br>26<br>25<br>24<br>23<br>22<br>21<br>20          | reserved channel  IE Status B  name 802.3Shrt BufOvr BadPkt InvldPrmbl CrcErr DrblNbbl CodeErr IpHdrShrt lpIncmplt IpSumErr TcpSumErr TcpHdrShrt         | The Mac on which this frame was received.  OFFSET 0x0004:0x0007  description  End of frame was encountered before the 802.3 length count was exhausted. The frame length exceded the buffer space available. Refer to E110 Technical Manual. The IP4 header length field contained a value less than 0x5. The frame terminated before the IP length counter was exhausted. The IP header checksum was not 0xffff at the completion of the IP header read. The session checksum was not 0xffff at the termination of session processing. The TCP header length field contained a value less than 0x5. The state of the frame processor at the time the frame processing terminated. 0b0000 Processing Mac header. 0b0001 Processing 802.3 LLC header. 0b0010 Processing 802.3 SNAP header. 0b0101 Processing IP header. 0b0101 Processing IP data (unknown transport). 0b0110 Processing transport header (IP data). 0b0111 Processing transport data (IP data). 0b1000 Processing IP processing complete.                                                                   |
| 02<br>01:00<br>FRAM<br>bit<br>31<br>30<br>29<br>28<br>27<br>26<br>25<br>24<br>23<br>22<br>21<br>20          | reserved channel  IE Status B  name 802.3Shrt BufOvr BadPkt InvldPrmbl CrcErr DrblNbbl CodeErr IpHdrShrt lpIncmplt IpSumErr TcpSumErr TcpHdrShrt         | The Mac on which this frame was received.  OFFSET 0x0004:0x0007  description  End of frame was encountered before the 802.3 length count was exhausted. The frame length exceded the buffer space available. Refer to E110 Technical Manual. The IP4 header length field contained a value less than 0x5. The frame terminated before the IP length counter was exhausted. The IP header checksum was not 0xffff at the completion of the IP header read. The session checksum was not 0xffff at the termination of session processing. The TCP header length field contained a value less than 0x5. The state of the frame processor at the time the frame processing terminated. 0b0000 Processing Mac header. 0b0010 Processing 802.3 SNAP header. 0b0011 Processing 802.3 SNAP header. 0b0010 Processing IP data (unknown transport). 0b0110 Processing IP data (unknown transport). 0b0111 Processing IP adata (unknown transport). 0b1001 Processing IP processing complete. 0b1001 Reserved.                                                                         |
| 02<br>01:00<br>FRAM<br>bit<br>31<br>30<br>29<br>28<br>27<br>26<br>25<br>24<br>23<br>22<br>21<br>20          | reserved channel  IE Status B  name 802.3Shrt BufOvr BadPkt InvldPrmbl CrcErr DrblNbbl CodeErr IpHdrShrt lpIncmplt IpSumErr TcpSumErr TcpHdrShrt         | The Mac on which this frame was received.  OFFSET 0x0004:0x0007  description  End of frame was encountered before the 802.3 length count was exhausted. The frame length exceded the buffer space available. Refer to E110 Technical Manual. The IP4 header length field contained a value less than 0x5. The frame terminated before the IP length counter was exhausted. The IP header checksum was not 0xffff at the completion of the IP header read. The session checksum was not 0xffff at the termination of session processing. The TCP header length field contained a value less than 0x5. The state of the frame processor at the time the frame processing terminated. 0b0000 Processing 802.3 LLC header. 0b0001 Processing 802.3 SNAP header. 0b0010 Processing IP deader. 0b0011 Processing IP data (unknown transport). 0b0110 Processing IP data (unknown transport). 0b0111 Processing transport data (IP data). 0b1011 Processing IP processing complete. 0b1001 Reserved.                                                                               |
| 02<br>01:00<br>FRAM<br>bit<br>31<br>30<br>29<br>28<br>27<br>26<br>25<br>24<br>23<br>22<br>21<br>20<br>19:16 | reserved channel  IE Status B  name 802.3Shrt BufOvr BadPkt InvldPrmbl CrcErr DrblNbbl CodeErr IpHdrShrt IpIncmplt IpSumErr TcpSümErr TcpHdrShrt PrcssCd | The Mac on which this frame was received.  OFFSET 0x0004:0x0007  description  End of frame was encountered before the 802.3 length count was exhausted. The frame length exceded the buffer space available. Refer to E110 Technical Manual. The IP4 header length field contained a value less than 0x5. The frame terminated before the IP length counter was exhausted. The IP header checksum was not 0xffff at the completion of the IP header read. The session checksum was not 0xffff at the termination of session processing. The TCP header length field contained a value less than 0x5. The state of the frame processor at the time the frame processing terminated. 0b0000 Processing Mac header. 0b0001 Processing 802.3 LLC header. 0b0010 Processing 802.3 SNAP header. 0b0010 Processing IP header. 0b0101 Processing IP header. 0b0101 Processing IP header. 0b0101 Processing IP data (unknown transport). 0b0111 Processing transport header (IP data). 0b1000 Processing transport data (IP data). 0b1001 Reserved. 0b101x Reserved. 0b11x Reserved. |
| 02<br>01:00<br>FRAM<br>bit<br>31<br>30<br>29<br>28<br>27<br>26<br>25<br>24<br>23<br>22<br>21<br>20          | reserved channel  IE Status B  name 802.3Shrt BufOvr BadPkt InvldPrmbl CrcErr DrblNbbl CodeErr IpHdrShrt lpIncmplt IpSumErr TcpSumErr TcpHdrShrt         | The Mac on which this frame was received.  OFFSET 0x0004:0x0007  description  End of frame was encountered before the 802.3 length count was exhausted. The frame length exceded the buffer space available. Refer to E110 Technical Manual. The IP4 header length field contained a value less than 0x5. The frame terminated before the IP length counter was exhausted. The IP header checksum was not 0xffff at the completion of the IP header read. The session checksum was not 0xffff at the termination of session processing. The TCP header length field contained a value less than 0x5. The state of the frame processor at the time the frame processing terminated. 0b0000 Processing 802.3 LLC header. 0b0001 Processing 802.3 SNAP header. 0b0010 Processing IP deader. 0b0011 Processing IP data (unknown transport). 0b0110 Processing IP data (unknown transport). 0b0111 Processing transport data (IP data). 0b1011 Processing IP processing complete. 0b1001 Reserved.                                                                               |

75/82





FIG. 86

#### TRANSMIT BUFFER DESCRIPTOR

| <u>bit</u> | name     | description                                                                                                                                                                                         |
|------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31         | ChksumEn | When set, XmtSeq will insert a calculated checksum. When reset, XmtSeq will                                                                                                                         |
|            |          | not alter the outgoing data stream.                                                                                                                                                                 |
| 30         | reserved |                                                                                                                                                                                                     |
| 29:28      | size     | Represents the size of the buffer by indicating at what boundary the buffer should start and terminate. This is used in combination with EndAddr to determine the starting address of the buffer:   |
|            |          | <ul> <li>S = 0 256B boundary. A[7:0] ignored.</li> <li>S = 1 2KB boundary. A[10:0] ignored.</li> <li>S = 2 4KB boundary. A[11:0] ignored.</li> <li>S = 3 32KB boundary. A[14:0] ignored.</li> </ul> |
| 27:00      | EndAddr  | The address of the last byte to transmit plus one.                                                                                                                                                  |

## FIG. 87

#### TRANSMIT BUFFER FORMAT

### CHECKSUM PRIMER OFFSET 0x0000:0x0003

| bit name<br>31:00 Primer | A value to be added during checksum accumulation. For IPV4, this should include the psuedo-header values, protocol and Tcp-length. |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------|
| RESERVED                 | OFFSET 0x0004:0x0005                                                                                                               |
| FRAME Data               | OFFSET 0x0006:END OF BUFFER                                                                                                        |

## FIG. 88

#### TRANSMIT Status VECTOR

| bit           | name           | description                                                           |
|---------------|----------------|-----------------------------------------------------------------------|
| <u>bit</u> 31 | LnkErr         | Indicates that a link status error occured before or during transmit. |
| 30:15         | reserved       |                                                                       |
| 14            | ExcessDeferral |                                                                       |
| 13            | LateAbort      | Refer to E110 Technical Manual.                                       |
| 12            | ExcessColl     | Refer to E110 Technical Manual.                                       |
| 11            | UnderRun       | Refer to E110 Technical Manual.                                       |
| 10            | ExcessLgth     | Refer to E110 Technical Manual.                                       |
| 09            | Okay           | Refer to E110 Technical Manual.                                       |
| 08            | deferred       | Refer to E110 Technical Manual.                                       |
| 07            | BrdCst         | Refer to E110 Technical Manual.                                       |
| 06            | MltCst         | Refer to E110 Technical Manual.                                       |
| 05            | CrcErr         | Refer to E110 Technical Manual.                                       |
| 04            | LateColl       | Refer to E110 Technical Manual.                                       |
| 03:00         | CollCnt        | Refer to E110 Technical Manual.                                       |





FIG. 91

#### **DMA OPERATIONS**

| dma seq # | name   | description                         |  |
|-----------|--------|-------------------------------------|--|
| 0         | none   | This is a no operation address.     |  |
| 1         | D2dSeq | Moves data from ExtMem to ExtMem.   |  |
| 2         | D2sSeq | Moves data from ExtMem bus to sram. |  |
| 3         | D2pSeq | Moves data from ExtMem to Pci bus.  |  |
| 4         | S2dSeg | Moves data from sram to ExtMem.     |  |
| 5         | S2pSeq | Moves data from sram to Pci bus.    |  |
| 6         | P2dSea | Moves data from Pci bus to ExtMem.  |  |
| 7         | P2sSeq | Moves data from Pci bus to sram.    |  |

## FIG. 92

| <u>bit</u><br>31:11 | name     | description                                                                           |
|---------------------|----------|---------------------------------------------------------------------------------------|
| 31:11               | reserved | Data written to these bits is ignored.                                                |
| 10:8                | ChCmd    | 0 - Stops execution of the current operation and clears the corresponding event flag. |
|                     |          | 1 - Transfer data from ExtMem to ExtMem.                                              |
|                     |          | 2 - Transfer data from ExtMem bus to sram.                                            |
|                     |          | 3 - Transfer data from ExtMem to Pci bus.                                             |
|                     |          | 4 - Transfer data from sram to ExtMem.                                                |
|                     |          | 5 - Transfer data from sram to Pci bus.                                               |
|                     |          | 6 - Transfer data from Pci bus to ExtMem.                                             |
|                     |          | 7 - Transfer data from Pci bus to Sram.                                               |
| 07:05               | reserved | Data written to these bits is ignored.                                                |
| 04:00               | Chld     | Provides the channel number for the channel command.                                  |

# FIG. 93

| bit    | name                    | description '                                                           |
|--------|-------------------------|-------------------------------------------------------------------------|
| 127:96 | <u>name</u><br>PciAddrH | Bits [63:32] of the Pci address.                                        |
| 95:64  | PciAddrL                | Bits [31:00] of the Pci address.                                        |
| 59:32  | MemAddr                 | Bits [27:00] of the ExtMem address or bits [15:00] of the Sram address. |
| 31     | PciEndian               | When set, selects big endian mode for Pci transfers.                    |
| 30     | WideDbl                 | When set, disables Pci 64-bit mode.                                     |
| 22     | DstFlash                | Selects Flash for the external memory destination of P2d.               |
| 15:00  | XfrSz                   | Bits [15:00] of the requested dma size expressed in bytes.              |

| <u>bit</u>           | name      | description                                                             |
|----------------------|-----------|-------------------------------------------------------------------------|
| <u>bit</u><br>123:96 | MemAddr   | Bits [27:00] of the ExtMem address or bits [15:00] of the Sram address. |
| 95:64                | PciAddrH  | Bits [63:32] of the Pci address.                                        |
| 63:32                | PciAddrL  | Bits [31:00] of the Pci address.                                        |
| 30                   | SrcFlash  | Selects Flash for the external memory source of D2p.                    |
| 23                   | PciEndian | When set, selects big endian mode for Pci transfers.                    |
| 22                   | WideDbl   | When set, disables Pci 64-bit mode.                                     |
| 15:00                | XfrSz     | Bits [15:00] of the requested dma size expressed in bytes.              |

# FIG. 95

| bit name<br>127:124 reserved | description                                                             |
|------------------------------|-------------------------------------------------------------------------|
| 127:124 reserved             | Reserved for future use.                                                |
| 123:96 SrcAddr               | Bits [27:00] of the ExtMem address or bits [15:00] of the Sram address. |
| 95:60 reserved               | Reserved for future use.                                                |
| 59:32 DstAddr                | Bits [27:00] of the ExtMem address or bits [15:00] of the Sram address. |
| 30 FlashSel                  | Selects Flash for the external memory source of D2d or D2s.             |
| 22 FlashSel                  | Selects Flash for the external memory destination of S2p or D2d.        |
| 15:00 <b>XfrSz</b>           | Bits [15:00] of the requested dma size expressed in bytes.              |

# FIG. 96

| <u>bit</u><br>127:64 | name      | description                                                                                                           |
|----------------------|-----------|-----------------------------------------------------------------------------------------------------------------------|
| 127:64               | reserved  | Not used.                                                                                                             |
| 63:32                | ChkSum    | Represents the 1's compliment sum of all halfwords transferred during a <b>P2d</b> or <b>D2d</b> operation only.      |
| 31:24                | reserved  | Reserved for future use.                                                                                              |
| 23:20                | SrcStatus | TBD.                                                                                                                  |
| 19:16                | DstStatus | TBD.                                                                                                                  |
| 15:00                | XfrSz     | Bits [15:00] of the residual dma size expressed in bytes. This value will be zero if the dma operation was successful |

| <u>bit</u> | name | description                                                                               |
|------------|------|-------------------------------------------------------------------------------------------|
| 31:00      | ChDn | Each bit represents the done flag for the respective dma channel. These bits are set by a |
|            |      | dma sequencer upon completion of the channel command. Cleared when the processor          |
|            |      | writes 0 to the corresponding ChCmd register ChCmdOp field.                               |

